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MULTI-INSTRUCTION SET FLAG PRESERVATION 
5 APPARATUS AND METHOD 

Field Of The Invention 

The invention relates generally to multi-instruction set processing devices and 
1 0 methods and more particularly to multi-instruction set processing devices and methods 
incorporating instruction emulation of instructions from one instruction set using 
instructions from the other instruction set. 

Background Of The Invention 

15 

Microprocessors and other instruction execution devices are known that employ 
variable length instruction sets, such as Intel® X86 family of microprocessors. Also, 
processors are known that execute different instruction sets, such as a variable length 
instruction set (e.g., X86 type instructions) and other instruction sets such as fixed length 

20 RISC instruction sets. With multi-instruction set processors, variable length instructions 
are sometimes converted to a plurality of fixed length native instructions to speed up 
execution of the variable length instruction. For example, an X86 based processor, may 
use a plurality of RISC instructions that may be fixed length instructions, to represent one 
or more variable length instructions. Typically, the RISC instructions are executed out of 

25 an onboard memory and are user accessible. An arithmetic logic unit, for example, may 
then receive the RISC instructions and execute the RISC instructions at a more efficient 
rate. Accordingly, integer instructions and other instructions may be converted from a 
non-native instruction to one or more native instructions. 

30 However, a problem can arise when variable length instructions, such as non- 

native instructions, require the setting of flags in various flag registers for particular 
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instructions. For example, if a set of variable length instruction are emulated using a 
plurality of fixed length native instructions and the fixed length native instructions update 
the flag registers that are used by other non-native instructions, the updating of the flags 
in the various flag registers during emulation can corrupt the state used by instructions 
5 being executed for other arithmetic logic units or other processor elements relying on the 
other variable length instructions being executed that also rely on the flag settings. One 
method of solving such a problem may be to save and restore flag states, but this can 
result in excessive overhead requirements. 

1 0 Consequently, there exists a need for a method and apparatus for processing 

program instructions in a multi-instruction set processing device, that helps suitably 
control the preservation of flag settings for variable length instructions that are emulated 
using fixed length native instructions. 

1 5 Brief Description Of The Drawings 

The invention will be more readily understood in view of the following drawings 
wherein: 

Figure 1 is a block diagram illustrating one example of a multiple processing 
device apparatus that employs use of native instructions having flag modification enable 
20 data in accordance with one embodiment of the invention; 

FIG. 2 is a block diagram illustrating one example of an apparatus for processing 
program instructions in accordance with one embodiment of the invention; 

FIG. 3 is a diagram illustrating one example of a native instruction format that 
includes flag modification enable bits in accordance with one embodiment of the 
25 invention; 

FIG. 4 is a graphic illustration depicting native emulation for nonconvertible 
variable length instructions and flag modification for converted variable length 
instructions in accordance with one embodiment of the invention; and 

FIG. 5a and FIG. 5b is a flow chart illustrating one example of the operation of 
30 the apparatus shown in FIG. 2. 
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Detailed Description Of a Preferred Embodiment of The Invention 

Briefly, a method and apparatus for processing program instructions, utilizes 
native fixed length instructions that include at least one flag modification enable bit. The 
flag modification enable bit is typically sent with the operation code and other 
5 information in the native instruction and is set to allow updating or prevention of 

updating of one or more flags, such as flags stored in flag registers associated with non- 
native instructions, such as variable length instructions. As such, a flag modification 
enable bit(s) may be set to preserve flag bit setting for variable length instructions that are 
emulated using the fixed length native instructions, to prevent overwriting of flag settings 
1 0 during emulation of variable length instructions. 

FIG. 1 illustrates an example of a multi-instruction set processing device 10 that 
includes a plurality of processing units 12a and 12b, such as microprocessors. The 
processing device 10 may be, for example, an integrated circuit. The processing device 

15 10 is operatively coupled to other processing devices (not shown) through a suitable bus 
14, such as a PCI bus used in personal computers, hand held devices and other portable 
devices. Memory 16, such as dynamic RAM (DRAM) or any other suitable memory, 
stores a software instruction emulation module 18 that is used to emulate variable length 
instructions that are not converted into a plurality of fixed length native instructions, as 

20 set forth below. 



If desired, the processing device 10 may include a memory gateway 20 and an I/O 
gateway 22. The memory gateway 20 may be a conventional memory gateway that is 
operatively coupled to the plurality of processing units 12a and 12b through a general bus 

25 24. Similarly, the I/O gateway 22 may serve as a gateway to allow communication with 
I/O chips through PCI bus 14. The I/O gateway 22 is operatively coupled to the plurality 
of processing units 12a and 12b through the bus 24. Each of the processors 12a and 12b 
receives native instructions 26 or non-native instructions over the general bus 24 through 
a suitable communication bus 28a and 28b. The native instruction 26 may be, for 

30 example, a fixed length instruction from a fixed length instruction set having operational 
code 30 and one or more flag modification enable bits 32, along with other suitable 
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instruction information. The non-native instruction may be variable byte length 
instructions, such as X86 type instructions. 

The software instruction emulation module 18 contains programming instructions 

5 to allow the emulation of variable length instructions, using a plurality of native 
instructions 26. The software instruction emulation module 18 is preferably run as 
needed by the plurality of processors 12a and 12b. In a preferred embodiment, the 
software instruction emulation module 18 is requested to emulate non-native instructions, 
such as complex variable length instructions, using native instructions 26 containing the 

1 0 flag modification bit 32. The non-native instructions that are emulated are preferably 
those instructions that are not convertible by an instruction set converter. For example, 
the emulated variable length instructions may be very complex X86 instructions that may 
be more quickly implemented and verified using the software emulation module 18 as 
opposed to a hardware based execution scheme. Some examples of X86 instructions that 

1 5 may be emulated include far call, task gate call and CPUID instructions. The software 
instruction emulation module 18 has the option of preventing the modification of flags, 
such as flags set when performing integer operations or other mathematical operations, in 
a flag register in response to execution of the plurality of native instructions used by the 
software instruction emulation module 18. Some emulated instruction modify the flags, 

20 while others preserve the flag settings. The software emulation module 18 contains 

instructions with the flag modification bit 32 set to inform the controller to modify or not 
modify flag settings as required. 

In contrast, when variable length instructions are suitably converted into fixed 
25 length native instructions by a converter, the arithmetic logic units executing the 
instructions are allowed to update the associated flags in the flag registers for those 
converted variable length instructions. 

Each of the processors 12a and 12b receive native instructions containing data 
30 representing operational code and data representing at least one flag modification enable 
bit 32 as part of the native instruction. The processors 12a and 12b determine whether 



5 



the flag modification enable bit 32 allows updating of ALU related flags, in response to 
executing the operational code. Each of the processors 12a and 12b may update the ALU 
flags in response to determining the status of the flag modification enable bit 32. For 
example, if the flag modification enable bit 32 is set to a logical high, indicating that flag 

5 modification is enabled, a processor may modify flags in a flag register in response to 
executing the native code during ALU execution of the native instructions. In contrast, if 
the flag modification enable bit is set, for example, to a logic zero, indicating flag 
modification is prevented, the processors are unable to write to the distributed flag 
register (FIG. 2), as is typically done during emulation of more complex variable length 

10 instructions. 

FIG. 2 illustrates one example of an apparatus 200 for processing program 
instructions that may be included in each of the processing units 12a and 12b. In this 
example, the apparatus 200 includes an instruction cache 202, an instruction multiplexer 

15 204, an instruction cache controller 206, a first buffer 208, an instruction aligner 210, an 
instruction aligner controller 212, an instruction converter 214, a multiplexer 216, a 
second buffer 218, and a plurality of arithmetic logic units 220a-220n that may include 
control logic 222. One or more flag registers 224 contain flags that are modified as 
required by the variable length instructions being executed. The flag registers may be 

20 distributed flag registers, meaning flag registers that are located throughout the processor, 
as desired. 

The bus 24 may transfer variable length instructions, referred to herein as non- 
native instructions, and fixed length instructions, referred to herein as native instructions. 
25 Native instructions are typically communicated to processing units 12a and 12b through 
bus 24 from memory 16 and cached in instruction cache 202. Variable length 
instructions (e.g., non-native instructions) are typically communicated through a bus 24 
from memory 16. 

30 The instruction cache 202 may be any suitable instruction cache that can cache 

variable length instructions, as well as fixed length instructions. The multiplexer 204 
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receives instructions 226 from the instruction cache 202 and/or instructions directly from 
the bus 24, indicated as instructions 228. The instruction cache controller 206, as known 
in the art, controls the multiplexer 204 to output selected instructions 230 for execution 
by, for example, one or more ALUs or other instruction execution stages. The selected 

5 instructions 230 are buffered in the first buffer 208 to allow the instruction aligner 210 to 
suitably align the variable length instructions under control of aligner controller 212. 
Any suitable variable length instruction alignment mechanism may be used. For 
example, a suitable instruction alignment mechanism may be one such as that found in 
co-pending application entitled "Variable Length Instruction Alignment Device and 

10 Method," filed by T.R. Ramesh et al., having attorney docket no. 0100.990098, owned by 
instant Assignee and incorporated herein by reference. Once the selected variable length 
instructions are suitably aligned, the converter 214 converts the one or more aligned 
variable length instructions to a plurality of native fixed length instructions through the 
use of hardwired logic indicated as 240. The aligned variable length instructions 238 

1 5 may also be of a complex type such that conversion is not appropriate. 

Converted instructions typically result in fewer than eight native instructions. 
When converting, the converter 214 converts, for example, variable length X86 
instructions to a plurality of resulting native instructions 240. The plurality of resulting 
20 native instructions 240 may include at least one flag modification enable bit 32 set to 
allow changing of non-native instruction flags in the flag register 224, in response to 
execution of the plurality of native instructions, by, for example, an ALU instruction 
execution stage. 

25 However, for the unconvertible non-native instructions 242, the converter 

generates an unconvertible instruction command indicating that emulation of the non- 
native instruction should be performed since conversion was not appropriate. The 
converter 214 generates the unconvertible instruction command in response to detecting 
that the X86 instruction is not convertible by the converter 214. The controller 222, upon 

30 receiving the unconvertible non-native instruction then requests the software instruction 
emulation module 18 to emulate the unconvertible non-native instruction 242. If a native 
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instruction is received on the bus 24, no conversion is necessary and the native 
instruction 244 will pass to the multiplexer 216. 

The controller 222 may be any suitable control logic and may be a part of one or 
more ALUs 220a-220n, or part of a converter or any other suitable block. The controller 
222 controls the multiplexer 216 to output native instruction 244 and native instructions 
240 resulting from a conversion, or unconvertible non-native instruction 242 into the 
second buffer 218. The controller 222 knows which of the input information 240 and 244 
to output to the second buffer, based on which instruction is being executed. 
Accordingly, the controller 222 outputs an address select signal 250 to control the 
multiplexer 216 to output a selected instruction 252 for storage in the second buffer 218. 
The second buffer 218, receives the instruction containing the operational code and data 
representing at least one flag modification enable bit in the form of native instruction 244 
or a native instruction 240 resulting from conversion. The controller 222 emits a 
command to buffer 21 8 to supply ALUs 220a-220n with instructions. The controller 222 
analyzes the instruction 256 taken from the second buffer 218 to determine whether the 
flag modification enable bit 32 (assuming a native instruction) allows modification of a 
flag in the flag register, in response to executing the operational code embedded in the 
native instruction. The controller 222 accordingly receives flag status data 258 indicating 
the status of the flag modification enable bit 32. If the flag modification enable bit 32 
indicates allowance of flag updates for the flag register, the controller 222 generates a 
flag update command 260 to update one or more flags in the flag register 224 in response 
to determining the status of the one flag modification enable bit 32. The flag register 224 
is operatively coupled to the controller 222 so that the controller can update a flag in the 
flag register if the native instruction flag modification native bit 32 is set to allow 
modification of the flag in the flag register. The ALUs perform integer instructions, e.g., 
add, subtract, etc., in native instructions then the control logic (controller) checks if the 
flag modification enable bit is set and updates flag reg if the bit is not set. The controller 
222 may also, if desired, provide the ALU execution stage with pipeline control 
information 262 indicating, for example, source operand availability. 
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In this embodiment, where the ALUs execute the native instructions containing 
the flag modification enable bits, the received instructions 256 include at least one of an 
integer instruction, an arithmetic instruction and a logical instruction. However, it will be 
recognized that non-integer instructions may also employ flag modification enable bits as 
5 desired. The ALUs may be any suitable arithmetic logic units, and may be, for example, 
of a type described in co-pending application entitled "Method and Apparatus of 
Configurable Processing," filed by inventors Korbin Van Dyke et al., having attorney 
docket no. 0100.9900930, filed on or about August 18, 1999 owned by instant assignee 
and incorporated herein by reference. 

10 

Referring to FIG. 3, one example of a native instruction 26 contains the flag 
modification enable bit 32, first operational code 30 (op code), size information 300, 
indicating, for example, the size of the operation which may be, for example, a 16-bit, 32- 
bit, 64-bit, 128-bit or any other suitable size, destination register of the operation 302 

15 indicating, for example, where to store results of the operation, first source register 

information 304 indicating the first register containing input data to the operation, second 
op code 306, second source information indicating the second register containing input 
data, and any other suitable information as desired. The native instruction 26 may be, for 
example, an add, subtract, multiply, divide, increment, decrement, negation, rotate, shift, 

20 XOR, AND, OR, or any other suitable instruction, for example, executable by the 

arithmetic logic units. The flag modification enable bit 32 may be designed so that if the 
bit is a "0" the flag settings in the flag registers cannot be affected through execution of 
the native instruction containing the flag modification bit, or if the bit is set to a logic 1, 
this state may indicate that the flag value may be modified based on the operation 

25 performed consistent with the native instruction. 

The native instruction 26 as shown includes at least one input operand and at least 
one destination operand (302 and 304), respectively. 

30 The software instruction emulation module 1 8, when executed by one or more of 

the processing units 12a, serves as a variable length instruction emulator that uses fixed 
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length native instructions to emulate variable length instructions. Programmers of 
software emulation module 18 typically set the flag modification enable bit of each native 
instruction to preserve flag bit settings for variable length instructions that are emulated 
using the fixed length native instructions. The non-native instruction emulator 18 
5 emulates unconverted variable length X86 instructions, for example, using a plurality of 
native instructions wherein the native instructions include the flag modification enable bit 
that may be set to prevent changing of non-native instruction flags in response to 
execution of the plurality of native instructions that are used to emulate the unconverted 
variable length instruction. 

10 

FIG. 4 graphically illustrates a queue of X86 instructions 400 wherein X86 
instruction 402 is not convertible. It is therefore emulated using native instructions from 
the native instruction set 404. In addition, the converter produces a sequence of native 
instructions. Where the native instructions have been generated based on conversion, the 
1 5 flag modification operation 406 is performed to modify one or more of the necessary 

flags in the flag register 224 as required by the native instructions. Flag register 224, by 
way of example, and not limitation, indicates various flags that may be set. For example, 
a zero flag, overflow flag, parity flag, sign flag, carry flag, or any other suitable flags. 

20 FIGS. 5a and 5b illustrate one example of the operation of the system of FIG. 2 

wherein the process includes storing received non-native variable length instructions in 
the instruction cache as shown in block 500. Since the non-native instructions are 
variable length and fetched in fixed length groups, the process includes aligning the 
variable length instructions, as shown in block 502, using the aligner 210. As shown in 

25 block 504, the converter, or other suitable logic, determines if the received variable 
length instruction is directly convertible to a plurality of native instructions. If the 
variable length instruction is unconvertible, the process continues as shown in block 506, 
by designating the instruction as unconverted, by using, for example, an unconvertible 
instruction command. This unconvertible instruction is then emulated by the software 

30 instruction emulation module. This may be carried out, for example, by the CPU calling 
the emulation module upon detection of the unconvertible instruction command. The 
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unconvertible instruction command may be any suitable data, such as any bits or any 
other suitable information such as appended to or indexed with the unconvertible variable 
instruction. 



5 However, if the aligned variable length instruction is convertible to a plurality of 

native instructions containing the flag modification enable bit, the process continues as 
shown in block 508 to convert the non-native instruction to native instructions. For 
example, an X86 ADD instruction where one operand is memory and the sequence is 
LDA T, MEM ADD 

10 ADD Dest, T 

As shown in block 512, the buffers or ALUs receive the native instructions 
containing the flag modification enable bits. The appropriate ALU then executes the 
resulting native instructions from the conversion as shown in block 514. As shown in 

1 5 block 516, the ALU determines whether the flag modification enable bit allows updating 
of the flag in a non-native instruction flag register, such as register 224. As shown in 
block 518, since the native instructions have been generated through conversion, the flag 
modification enable bit should be set so that it allows setting of flags. Accordingly, the 
process includes updating one or more flags in the flag register in response to 

20 determining the status of the modification enable bit. The process then ends for that 
instruction and continues for other instructions, as shown in block 520. 

Referring back to block 506, if the instruction received from the bus 24 has been 
designated as an unconverted instruction so that it is passed for emulation by the 

25 instruction emulator, the process includes, as shown in block 522, emulating the 
unconvertible non-native instructions using native instructions containing the flag 
modification enable bits. The native instructions used to emulate the unconvertible non- 
native instructions typically have the flag modification enable bits set to prevent updating 
of the flag register 224 to avoid overwriting of flags that may be being set by other 

30 instructions that are being executed. As shown in block 524, the process includes 

determining whether the flag modification enable bit allows updating of the flag in the 
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non-native instruction flag register (flag register 224) so that, for example, if the bit is set 
to prevent changing, as shown in block 526, the process includes preventing changing of 
flags for the emulated instructions based on the state of the flag of the modification 
enable bit for a given native instruction. 

5 

Accordingly, the above apparatus and methods can provide multi-instruction set 
processing units with faster execution by allowing some instructions to be converted for 
direct execution by an ALU. However, for those instructions that require emulation, 
flags may be prevented from being modified during the execution of emulation to 
10 eliminate the need to save and restore the flag registers. Hence, the disclosed apparatus 
and method allow flexibility in the ordering of instructions and the modification of flags 
and use of flags. 

It should be understood that the implementation of other variations and 
1 5 modifications of the invention in its various aspects will be apparent to those of ordinary 
skill in the art, and that the invention is not limited by the specific embodiments 
described. For example, the apparatus and methods may be implemented using any 
suitable combination of hardware, software and firmware. Also, the functions of one 
element may be shared or varied to other suitable elements as desired. It is therefore 
20 contemplated to cover by the present invention, any and all modifications, variations, or 
equivalents that fall within the spirit and scope of the basic underlying principles 
disclosed and claimed herein. 
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Claims 



WHAT IS CLAIMED IS: 

1 . A method for processing program instructions comprising the steps of: 

receiving at least one instruction containing data representing operational 
code and data representing at least one flag modification enable bit; 

determining whether the at least one flag modification enable bit allows 
updating of at least one flag in response to executing the operational code; and 

updating at least one flag in response to determining a status of the at least 
one flag modification enable bit. 

2. The method of claim 1 wherein the at least one instruction is at least one of: an 
integer instruction, an arithmetic instruction and a logical instruction. 

3. The method of claim 1 wherein the at least one instruction includes at least one 
input operand. 

4. The method of claim 1 wherein the step of updating at least one flag in response 
to determining a status of the at least one flag modification enable bit, includes 
updating a flag register if the flag modification enable bit is set to allow 
modification of a flag in the flag register. 

5. The method of claim 1 including the steps of: 

providing a variable length instruction emulator that uses fixed 
length native instructions as the at least one instruction, to emulate 
variable length instructions; and 

evaluating the flag modification enable bit to preserve flag bit 
settings for variable length instructions that are emulated using the fixed 
length native instructions. 



13 



The method of claim 1 wherein the at least one instruction is a fixed length 
instruction. 

The method of claim 1 including the step of emulating non-native instructions 
using native instructions containing the flag modification bit. 

The method of claim 7 wherein the non-native instructions are variable length 
X86 instructions. 

The method of claim 8 including the steps of: 

converting variable length X86 instructions to a plurality of native 
instructions wherein the plurality of native instructions include the at least one 
flag modification enable bit set to allow changing of non-native instruction flags 
in response to execution of the plurality of native instructions; and 

emulating unconverted variable length X86 instructions using a plurality 
of native instructions wherein the native instructions include the at least one flag 
modification enable bit set to prevent changing of non-native instruction flags in 
response to execution of the plurality of native instructions. 
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10, An apparatus for processing program instructions comprising: 

a buffer coupled to receive at least one instruction containing data 
representing operational code and data representing at least one flag modification 
enable bit; and 

a controller operatively responsive to the at least one instruction stored in 
the buffer, that determines whether the at least one flag modification enable bit 
allows updating of at least one flag in response to executing the operational code 
and that updates at least one flag in response to determining a status of the at least 
one flag modification enable bit. 

1 1 . The apparatus of claim 10 wherein the at least one instruction is at least one of: an 
integer instruction, an arithmetic instruction and a logical instruction. 



12. The apparatus of claim 1 1 wherein the at least one instruction includes at least one 
15 input operand. 

13. The apparatus of claim 10 including a flag register operatively coupled to the 
controller, wherein the controller updates a flag in the flag register if the flag 
modification enable bit is set to allow modification of the flag in the flag register. 

20 

14. The apparatus of claim 10 including a variable length instruction emulator that 
uses fixed length native instructions as the at least one instruction, to emulate 
variable length instructions. 

25 15. The apparatus of claim 10 wherein the at least one instruction is a fixed length 
instruction. 

16. The apparatus of claim 14 wherein the variable length instruction emulator 
emulates non-native instructions using native instructions containing the flag 
3 0 modification bit. 
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The apparatus of claim 16 wherein the non-native instructions are variable length 
X86 instructions. 

The apparatus of claim 17 including: 

an instruction converter, operatively coupled to receive variable length 
X86 instructions, that converts the received variable length X86 instructions to a 
plurality of native instructions wherein the plurality of native instructions include 
the at least one flag modification enable bit set to allow changing of non-native 
instruction flags in response to execution of the plurality of native instructions; 
and 

a non-native instruction emulator operatively responsive to an 
unconvertible instruction command generated in response to detecting that an X86 
instruction is not convertible by the converter, wherein the non-native instruction 
emulator emulates unconverted variable length X86 instructions using a plurality 
of native instructions wherein the native instructions include the at least one flag 
modification enable bit set to prevent changing of non-native instruction flags in 
response to execution of the plurality of native instructions for the unconverted 
variable length instruction. 
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MULTI-INSTRUCTION SET FLAG PRESERVATION 
APPARATUS AND METHOD 



Abstract Of The Invention 

5 

A method and apparatus for processing program instructions, utilizes native fixed 
length instructions that include at least one flag modification enable bit. The flag 
modification enable bit is typically sent with the operation code and other information in 
the native instruction and is set to allow updating of one or more flags, such as stored in 
1 0 flag registers, associated with non-native instructions, such as variable length 

instructions. In addition, a flag modification enable bit may be set to preserve flag bit 
setting for variable length instructions that are emulated using the fixed length native 
instructions, to prevent overwriting of flag settings during emulation of variable length 
instructions. 
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specification of which: 

|§] is attached hereto, 

□ was file on (MM/DD/YYYY) as United States Application Number or PCT International Application 

Number and was amended on (MM/DD/YYYY) (if applicable). 

I hereby state that I have reviewed and understand the contents of the above identified specification, including the 
claims, as amended by any amendment specifically referred to above. 

I acknowledge the duty to disclose information which is material to patentability as defined in 37 CFR 1 .56. 

I hereby claim foreign priority benefits under 35 U.S.C. 1 19(a)-(d) or 365(b) of any foreign application(s) for patent or inventor's certificate, or 365(a) 
of any PCT international application which designated at least one country other than the United States of America, listed below and have also 
identified below, by checking the box, any foreign application for patent or inventor's certificate, or of any PCT international application having a 
filing date before that of the application on which priority is claimed, 



Prior Foreign 
Application Number(s) 


Country 


Foreign Filing Date 
(MM/DD/YYYY) 


Priority Not j Certified Copy Attached? 
Claimed YES NO 










□ 1 □ □ 










□ i □ □ 



[~1 Additional foreign application numbers are listed on a supplemental priority data sheet PTO/SB/02B attached hereto. 



I hereby claim the benefit under 35 U.S.C. 119(e) of any United States provisional application^ ) listed below. 



Application Nuniber(s) 


Filing Data (MM/DD/YYYY) 











1 1 Additional provisional application numbers are listed on a supplemental priority data sheet PTQ/SB/021'i attached hereto. 



1 hereby claim the benefit under 35 U.S.C, 120 of any United States applications), or 365(c) of any PCT international application designating the 
United States of America, listed below and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior United 
States or PCT International application in the manner provided by the first paragraph of 35 U.S.C. 112, 1 acknowledge the duty to disclose 
information which is material to patentability as defined in 37 CFR 1.56 which became available between the filing date of the prior application and 
the national or PCT international filing date of this application. 



U.S. Parent Application or PCT 
Parent Number 


Parent Filing Date 
(MM/DD/YYYY) 


Parent Patent Number 
(if applicable) 















□ Additional U.S. or PCT international application numbers are listed on a supplemental priority data sheet PTO/SB/02B attached hereto. 



Attorney Docket Number 0100.9900960 
First Named Inventor Doe A, Van Dyke 

COMPLETE IF KNOWN 
Application Number 
Filing Date 
Group Art Unit 
Examiner Name 



11/08 '99 16:55 



11/08/99 MON 14:49 FAX 408 845 6302 



ATI RESEARCH SILICON VLY 



Sj009 



As a named inventor, I hereby appoint the following registered practitioner(s) to prosecute this application and to 



transact all business in the ] 


Patent and Trademark Office connected therewith: 


Name 


Registration Number 


Name 


Registration Number 


Timothy W. Markison 


33,534 


Christopher J. Reckamp 


34,414 


Paul M. Anderson 


39,896 






Sally Daub 


41,478 







□ Additional registered practitioner^) named on supplemental Registered Practitioner Information sheet PTO/SB/02C attached hereto. 



Direct all correspondence to: Markison & Reckamp, P.C 

175 West Jackson Boulevard - Suite 1015 
Chicago, Illinois 60604 
Telephone;312-939-9800 
Facsimile: 312-939-9828 

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on 
information and belief are believed to be true; and further that these statements were made with the knowledge that 
willful false statements and the like so made are punishable by fine or imprisonment, or both, under 18 U.S.C. 1001 and 
that such willful false statements may jeopardize the validity of the application or any patent issued thereon. 



Name of Sole or First Inventor: 


□ A petition has been filed for this unsigned inventor 


Given Name (first and middle [if any]) 


Family Name or Surname 


Don A... SI a /~) 


Van Dyke 


Inventor's 
Signature 






Residence 


CUv: Pleasanton sta#: CA 


Country: USA 


Citizenship: USA 


Post Office 


Address 5133 Independence Drive 


City: Pleasanton I State: C A 


ZIP: 94566 Country: USA 



Name of Additional Joint Inventor: □ A petition has been filed for this unsigned inventor 



Given Name (first and middle [if any]) 


Family Name or Surname 






Inventor's 
Signature 


| Date 




Residence 


City: 


State: 


Country: Citizenship: 


Post Office 


Address 


City: 


State: | ZIP: 


Country: 


Name of Additional Joint Inventor: 


A petition has been filed for this unsigned inventor 


Given Name (first and middle [if any]) 


Family Name or Surname 






Inventor's 
Signature 


Date 




Residence 


City: 


State: 


Country: Citizenship: 


Post Office 


Address 


City: 


State: 


ZIP: 


Country: 



Efl Additional inventors are being named on the _l_supplemental Additional Inventor(s) sheetPTO/SB/02A attached hereto. 



11/08 '99 16:55 



